@charset "utf-8";
@import url("https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css");

:where(#bo_v:has(.view-content)) * { color: var(--color-point) !important; }

.review-board,
#bo_list,
#bo_w,
#bo_v,
.review-list {
	font-family: "Pretendard", -apple-system, BlinkMacSystemFont, system-ui, Roboto, "Helvetica Neue", "Segoe UI", "Apple SD Gothic Neo", "Noto Sans KR", "Malgun Gothic", sans-serif !important;
}

.bo_fx { position: relative; padding: 20px 0; }
.bo_fx .chk_all { position: absolute; left: 5px; top: 20px; }

.board-category { display: block; position: relative; margin-bottom: 10px; }
.board-category select {}

.board-write { padding: 0 10px; }
.board-write h3 { font-size: 26px; text-align: center; padding: 30px 0 20px; }
.board-write .write-notice { padding: 10px; font-size: 11px; }
.board-write > dl { position: relative; }
.board-write > dl > dt { width: 70px; position: absolute; line-height: 32px; text-align: center; }
.board-write > dl > dd { width: 100%; margin-left: 0; padding-left: 80px; box-sizing: border-box; line-height: 32px; }
.board-write input.frm_input.full { width: 100%; display: block; margin: 1px 0; }

.board-viewer.theme-box { display: block; position: relative; padding: 20px; }
.theme-box .board-comment-list { background-color: #00000030 !important; border: none !important; }
.board-viewer .subject { text-align: center; }
.board-viewer .subject em { display: block; position: relative; font-size: 14px; line-height: 1.2; padding-bottom: 10px; }
.board-viewer .subject strong { display: block; position: relative; font-size: 22px; line-height: 1.2; }
.board-viewer .info { margin-top: 20px; padding: 8px 10px; text-align: center; }
.board-viewer .info span { display: inline-block; opacity: .8; }
.board-viewer .info span + span:before { content: ""; display: inline-block; width: 1px; height: 8px; vertical-align: middle; margin: 0 10px; }
.board-viewer .contents { display: block; position: relative; margin: 20px 0; padding: 40px 15px; border-left-width: 0; border-right-width: 0; }

#bo_v_bot { padding: 20px 0; overflow: hidden; }
.bo_v_nb { float: left; }
.bo_v_com { float: right; }

.board-comment-list { position: relative; }
.board-comment-list .co-line { display: block; position: relative; clear: both; width: 100%; height: 1px; margin: 0; padding: 0; border: none; }
.board-comment-list .item { position: relative; padding: 10px; }
.board-comment-list .co-name { position: relative; width: auto; top: 0; left: 0; bottom: 0; box-sizing: border-box; color:var(--effect-point) !important;}
.board-comment-list .co-info { display: block; text-align: right; font-size: 11px; opacity: .7; }
.board-comment-list .co-info span { display: inline-block; opacity: .8; }
.board-comment-list .co-info span + span:before { content: ""; display: inline-block; width: 1px; height: 8px; vertical-align: middle; margin: 0 10px; }
.board-comment-list .item.reply { border-left: 5px solid rgba(255,255,255,.1); }
.board-comment-list .item.reply .co-name { background: none; }
.board-comment-list + .board-comment-write { margin-top: 20px; }

.board-comment-form { position: relative; padding-right: 80px; }
.board-comment-form .btn_confirm { position: absolute; top: 0; right: 0; bottom: 29px; width: 80px; }
.board-comment-form .btn_confirm .ui-btn { width: 100%; height: 100%; background: #000 !important; }
.board-comment-form .btn_confirm .ui-btn:hover,.board-comment-form .btn_confirm .ui-btn:focus {	background: #252525 !important; }
.board-comment-form p { margin: 0; padding: 5px 10px; }
.board-comment-form textarea { display: block; height: 100px; resize: none; border: none; background-color: #000 !important; transition: background-color 0.15s;}

.co-inner { color: #eee !important; }

#rating-stars { font-size: 24px; color: #f39c12; cursor: pointer; line-height: 1; }
.rating-input { width: 50px; text-align: center; }
dd.rating-wrap { display: flex; align-items: center; gap: 6px; }

.form-bpd { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); row-gap: 12px; }
.form-bpd dl { display: grid; grid-template-columns: 90px 1fr; align-items: center; margin: 0; padding: 0; }
.form-bpd dt { margin: auto; }
.form-bpd dd { margin: 0; margin-left: -0.8em; }
.form-bpd .date-wrap { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 6px; }
.form-bpd select.frm_input,
.form-bpd input[type="date"].frm_input { width: 100%; min-width: 0; box-sizing: border-box; }

.top-line { display: flex; flex-wrap: wrap; align-items: center; gap: 12px 16px; margin-left: 2em; }
.top-line label { margin-right: 4px; white-space: nowrap; line-height: 2.5; }
.top-line select,
.top-line input[type="text"] { height: 32px; line-height: 32px; padding: 0 8px; box-sizing: border-box; margin-left: 2.5em; }
.top-inline .item { display: inline-flex; align-items: center; gap: 6px; }

.poster-grid { display: grid; grid-template-columns: auto 1fr; gap: 8px; }
.poster-grid input[type="text"] { width: 100% !important; box-sizing: border-box; }

.review-list { display: flex; flex-direction: row; flex-wrap: wrap; gap: 18px; margin: 0 auto; }
.review-item { position: relative; border-radius: 12px; overflow: hidden; background: #111; color: #fff; width: var(--card-width); height: var(--card-height); min-height: 250px; max-height: 1000px; box-shadow: 0 0 10px #00000042; }
.review-item::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 65%; background: linear-gradient(to top, rgba(0,0,0,.88) 0%, rgba(0,0,0,.55) 60%, rgba(0,0,0,0) 100%); z-index: 1; pointer-events: none; }

.review-item .card-link { position: absolute; inset: 0; z-index: 9; background: transparent; }
.review-item .card-link:hover { cursor: pointer; }

.review-item.is-blind .review-thumb { filter: blur(10px); -webkit-filter: blur(10px); transform: scale(1.02); position: relative; }
.review-item.is-blind .review-cover-blind { display: none !important; }

.review-thumb { position: absolute; inset: 0; background-size: cover; background-position: center; z-index: 0; width: 100%; height: 100%; }
.review-cover-blind { position: absolute; inset: 0; background: repeating-linear-gradient(45deg, rgba(0,0,0,.8), rgba(0,0,0,.8) 10px, rgba(255,255,255,.2) 10px, rgba(255,255,255,.2) 20px); z-index: 2; }

.review-meta { position: absolute; top: 10px; right: 10px; background: rgba(0,0,0,.55); padding: 5px 10px; border-radius: 16px; font-size: 12px; z-index: 4; }

.review-content { position: absolute; bottom: 20px; left: 20px; right: 20px; display: flex; flex-direction: column; align-items: flex-start; gap: 8px; z-index: 3; }
.review-content .rating-line,
.review-content .review-title { display: block; }
.review-content .hashtags { position: absolute; bottom: 0; right: 0; display: flex; flex-wrap: wrap; width: 50%; max-width: 50%; justify-content: flex-end; gap: 6px; }
.review-content .hashtags span { display: inline-block; background: #fff; color: #222; font-size: 12px; line-height: 1; padding: 6px 10px; border-radius: 999px; white-space: nowrap; }

.rating-line { display: flex; align-items: center; gap: 8px; font-size: 14px; opacity: .95; }
.rating-stars { display: inline-flex; gap: 2px; font-size: 1em; line-height: 1; }
.rating-stars .star { position: relative; display: inline-block; color: #ddd; }
.rating-stars .star.full { color: #f5c342; font-size: 12px; bottom: -5px; }
.rating-stars .star.empty { color: #555; font-size: 12px; bottom: -5px; }
.rating-stars .star.half { color: #dddddd3d; font-size: 12px; bottom: -5px; }
.rating-stars .star.half::before { content: "★"; color: #f5c342 !important; position: absolute; left: 0; width: 50%; overflow: hidden; }
.rating-stars .star.full2 { color: #f5c342 !important; margin-bottom: 10px; }
.rating-stars .star.empty2 { color: #555 !important; margin-bottom: 10px; }
.rating-stars .star.half2 { color: #dddddd3d !important; margin-bottom: 10px; }
.rating-stars .star.half2::before { content: "★"; color: #f5c342 !important; position: absolute; left: 0; width: 50%; overflow: hidden; }

.review-title { font-size: 22px; font-weight: 800; line-height: 1.25; white-space: normal; overflow: hidden; text-overflow: ellipsis; max-width: 50%; }
.review-title a { display: inline-block; font-weight: 800; font-size: 22px; color: #fff !important; text-decoration: none; text-shadow: 0 2px 8px rgba(0,0,0,.45); }

.hashtags { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; justify-content: flex-end; margin-top: 10px; }
.hashtags span { display: inline-block; margin-right: 6px; margin-bottom: 6px; padding: 6px 10px; border-radius: 999px; background: rgba(255,255,255,.1); color: #eee; font-size: 12px; line-height: 1; border: 1px solid rgba(255,255,255,.18); }

.review-summary { position: absolute; inset: 0; z-index: 6; background: rgba(0,0,0,.88); color: #fff; padding: 50px; opacity: 0; transition: opacity .25s ease; overflow-y: auto; font-size: 14px; line-height: 1.6; pointer-events: none; }
.review-item:hover .review-summary { opacity: 1; }

#bo_cate { text-align: center; }
#bo_cate li { display: inline-block; vertical-align: middle; margin: 0 0 2em .2em; }

#bo_list .review-item .review-summary {
	display: -webkit-box !important;
	-webkit-line-clamp: 6;
	-webkit-box-orient: vertical;
	overflow: hidden !important;
	text-overflow: ellipsis;
	white-space: normal !important;
	line-height: 1.6;
	height: auto !important;
	max-height: calc(1.6em * 6) !important;
}

.view-fullbleed.view-fullbleed { position: relative; min-height: 100vh; display: flex; flex-direction: column; align-items: flex-end; padding: 5% 0 0 0; font-family: "Pretendard"; }
.view-fullbleed::before {
	content: "";
	position: fixed;
	inset: 0;
	z-index: -1;
	background-image:
		linear-gradient(to right, rgba(255,255,255,.05) 0%, rgba(0,0,0,.85) 40%, rgba(0,0,0,1) 100%),
		var(--view-bg);
	background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
	background-attachment: fixed;
}

.content-wrap { max-width: 800px; text-align: left; color: #fff; }

.title { font-size: 2.5rem; font-weight: 700; color: #fff !important; margin-bottom: 10px; line-height: 1; word-break: keep-all; overflow-wrap: break-word; }
.rating { font-size: 1.2rem; margin-bottom: .5em; }
.date { font-size: .95rem; margin-bottom: .8em; opacity: .85; }
.tags { margin-bottom: 1em; }
.tag { display: inline-block; margin: 0 .25em .25em 0; padding: .3em .8em; color: #fff !important; background: rgba(255,255,255,.15) !important; border-radius: 999px; font-size: .85rem; }

.star { font-size: 24px; color: #f5c518; position: relative; display: inline-block; line-height: 1; }
.star.empty { color: #55555531; }
.star.half { color: #555; }
.star.half::before { content: "★"; color: #f5c518; position: absolute; left: 0; width: 50%; overflow: hidden; }

.subnote { margin: 8px 0 14px; font-size: 14px; line-height: 1.6; color: rgba(255,255,255,.85); letter-spacing: .2px; }
.line-view { width: 100%; height: 1px; background: rgba(255,255,255,.65); margin: 12px 0 18px; }

.fix-layout:has(#bo_v.view-fullbleed) {
	max-width: 1600px !important;
	margin: 10 !important;
	padding: 0 !important;
	display: grid !important;
	grid-template-columns: 1fr minmax(900px, 40vw) !important;
	column-gap: 5vw !important;
}
.fix-layout:has(#bo_v.view-fullbleed) #bo_v.view-fullbleed { grid-column: 2 !important; width: 100% !important; }
#bo_v.view-fullbleed .content-wrap { width: 100% !important; }

.view-content { font-size: .8rem; line-height: 1.6; color: #eee !important; }

a.blur-txt { filter: blur(5px); color: currentColor; cursor: pointer; }
a.none-blur { filter: blur(0); font-family: inherit; }
span.italictext { font-style: italic; font-family: inherit; }
span.txt-box { color: <?=$css['color_default'][0]?>; background-color: <?=$css['color_point'][0]?>; padding: 0 2px; }
.blurtext { filter: blur(3px); -webkit-filter: blur(3px); transition: filter .2s ease, -webkit-filter .2s ease; }
.blurtext.off { filter: blur(0) !important; }

@media all and (max-width: 640px) {
	#bo_v_con * { max-width: 100%; }

	.board-category { display: block; width: 100%; box-sizing: border-box; padding: 0 10px; }
	.board-category select { width: 100%; }

	.bo_fx { display: block; width: 100%; box-sizing: border-box; padding: 20px 10px !important; }
	.bo_fx a { display: block; width: 100%; }

	.board-comment-list .item { padding: 0; }
	.board-comment-list .co-content { padding: 10px; word-break: break-all; }
}

@media (max-width: 800px) {
	.review-item { width: 100%; }
}

@media (max-width: 820px) {
	.fix-layout:has(#bo_v.view-fullbleed) {
		display: block !important;
		grid-template-columns: 1fr !important;
		column-gap: 0 !important;
		max-width: 100% !important;
		margin: 0 !important;
		padding: 0 !important;
	}
	.fix-layout:has(#bo_v.view-fullbleed) #bo_v.view-fullbleed { grid-column: 1 / -1 !important; width: 100% !important; }
	#bo_v.view-fullbleed { align-items: center !important; padding: 6% 0 0 !important; }
	#bo_v.view-fullbleed .content-wrap { width: 92% !important; max-width: 720px !important; margin: 0 auto !important; padding: 40px 16px !important; }
}
